package top.lixunda.ecommerce.server.good.service;

import com.baomidou.mybatisplus.extension.service.IService;
import top.lixunda.ecommerce.server.good.api.entity.db.SysStoreCategoryDO;
import top.lixunda.ecommerce.server.good.api.entity.dto.StoreCategoryInsertDTO;
import top.lixunda.ecommerce.server.good.api.entity.dto.StoreCategoryUpdateDTO;

import java.util.List;

/**
 * <p>
 * 店铺类别静态表，管理员进行管理 服务类
 * </p>
 *
 * @author Xumda
 * @since 2019-12-18
 */
public interface ISysStoreCategoryService extends IService<SysStoreCategoryDO> {

    /**
     * 添加一个店铺分类
     *
     * @param storeCategoryInsertDTO 新添加的店铺分类数据
     * @return 是否添加成功
     */
    boolean insertStoreCategory(StoreCategoryInsertDTO storeCategoryInsertDTO);

    /**
     * 更新一个店铺分类
     *
     * @param storeCategoryUpdateDTO 需要更新的店铺分类数据
     * @return 是否更新成功
     */
    boolean updateStoreCategory(StoreCategoryUpdateDTO storeCategoryUpdateDTO);

    /**
     * 根据id删除店铺分类，只删除该节点，其子节点全部放到父节点中去
     *
     * @param id 店铺分类id
     * @return 是否删除成功
     */
    boolean removeStoreCategoryById(Integer id);

    /**
     * 根据id删除店铺分类，只删除该节点，其子节点全部放到父节点中去
     *
     * @param ids 店铺分类id
     * @return 是否删除成功
     */
    boolean removeStoreCategoryByIds(List<Integer> ids);

    /**
     * 根据id删除店铺分类，删除包括子节点的所有节点
     *
     * @param id 店铺分类id
     * @return 是否删除成功
     */
    boolean removeStoreCategoryAllById(Integer id);

    /**
     * 根据id删除店铺分类，删除包括子节点的所有节点
     *
     * @param ids 店铺分类id
     * @return 是否删除成功
     */
    boolean removeStoreCategoryAllByIds(List<Integer> ids);

    /**
     * 根据id获取分类数据
     *
     * @param id 分类id
     * @return 单条分类数据
     */
    SysStoreCategoryDO queryById(Integer id);

    /**
     * 查询所有分类信息
     *
     * @return 所有分类信息
     */
    List<SysStoreCategoryDO> queryAll();

    /**
     * 根据父节点id获取子类节点列表
     *
     * @param id 父节点id
     * @return 子节点列表
     */
    List<SysStoreCategoryDO> queryChildrenByParentId(Integer id);

    /**
     * 查询首层节点
     *
     * @return 首层节点
     */
    List<SysStoreCategoryDO> queryRoots();

}
